/**
* @author:kellen
* @contact:xiekellen@hotmail.com
* @company:achivo-gz
* @created on:
* @modified on:
*/

package com.sasis.dao.ibatis;

import java.util.List;

import com.sasis.dao.ibatis.BaseDaoiBATIS;
import com.sasis.model.Hotel;
import com.sasis.dao.HotelDao;

import org.springframework.orm.ObjectRetrievalFailureException;

public class HotelDaoiBatis extends BaseDaoiBATIS implements HotelDao {

    /**
     * @see com.sasis.dao.HotelDao#getHotels(com.sasis.model.Hotel)
     */
    public List getHotels(final Hotel hotel) {
          return getSqlMapClientTemplate().queryForList("getHotels", hotel);
    }

    /**
     * @see com.sasis.dao.HotelDao#getHotel(Integer id)
     */
    public Hotel getHotel(Integer id) {
        Hotel hotel = (Hotel) getSqlMapClientTemplate().queryForObject("getHotel", id);

        if (hotel == null) {
            throw new ObjectRetrievalFailureException(Hotel.class, id);
        }

        return hotel;
    }

    /**
     * @see com.sasis.dao.HotelDao#saveHotel(Hotel hotel)
     */    
    public void saveHotel(final Hotel hotel) {
        Integer id = hotel.getId();
        // check for new record
        if (id == null) {
            id = (Integer) getSqlMapClientTemplate().insert("addHotel", hotel);
        } else {
            getSqlMapClientTemplate().update("updateHotel", hotel);
        }
        if( id == null ) {
            throw new ObjectRetrievalFailureException(Hotel.class, id);
        }
    }

    /**
     * @see com.sasis.dao.HotelDao#removeHotel(Integer id)
     */
    public void removeHotel(Hotel hotel) {
        getSqlMapClientTemplate().update("deleteHotel",  hotel);
    }
}
